import java.util.ArrayList;

public class test2promax{
    public static void main(String[] args) {
        int limit = 20000;
        ArrayList<Integer> primes = new ArrayList<>();
        boolean[] isPrime = new boolean[limit + 1];

        // 初始化所有数为素数
        for (int i = 2; i <= limit; i++) {
            isPrime[i] = true;
        }

        // 线性筛法
        for (int i = 2; i <= limit; i++) {
            if (isPrime[i]) {
                primes.add(i);
            }
            for (int j = 0; j < primes.size() && i * primes.get(j) <= limit; j++) {
                isPrime[i * primes.get(j)] = false;
                if (i % primes.get(j) == 0) {
                    break;
                }
            }
        }

        // 打印素数，每行5个
        for (int i = 0; i < primes.size(); i++) {
            System.out.print(primes.get(i) + "\t");
            if ((i + 1) % 5 == 0) {
                System.out.println();
            }
        }
    }
}

